草庐IT

mysql - 多个join的SQL查询

全部标签

ruby - 按升序和降序对多个值进行排序

我正在尝试根据不同的属性对一组对象进行排序。其中一些属性我想按升序排序,一些属性按降序排序。我已经能够按升序或降序进行排序,但无法将两者结合起来。这是我正在使用的简单类:classDogattr_reader:name,:genderDOGS=[]definitialize(name,gender)@name=name@gender=genderDOGS然后我可以实例化一些狗,稍后进行分类。@rover=Dog.new("Rover","Male")@max=Dog.new("Max","Male")@fluffy=Dog.new("Fluffy","Female")@cocoa=Do

ruby - 你如何在 Thor 中指定多个参数或参数?

my_gem你好name1name2name3给我一个my_gemhellorequiresatleast1argument:my_gemhelloname我应该只解析它们并用定界符分隔参数吗?例如my_gemhelloname1,name2,name3,nameN在文件中它看起来像classMyCLI或者有没有办法做到这一点? 最佳答案 是的,还有另一种方法。require'thor'classTestApp它可以这样调用:$thortest_app:hellofirstsecondthirdhellofirst;second;t

ruby-on-rails - Development.log 日志文件不记录 Rails SQL 查询

我在这里关注MichaelHartl的Rails教程:http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-one#top我使用此命令在单独的窗口中跟踪SQL查询:tail-flog/development.log然而,当我在沙盒Rails控制台中时,日志不会用SQL语句更新,而是显示在Rails控制台中。我该如何纠正这种行为?我应该补充一点,我的数据库迁移和对数据模型(新表等)的更改都反射(reflect)在日志中。仅省略由Rails控制台内的方法传播的SQL语句(而是显示在Rails控制台中)。这是我的G

ruby-on-rails - Ruby Gem ActiveRecord 具有多个条件的查找方法

我正在使用三个数据库表构建一个Sinatra应用程序:user、post和like。我想运行一个查询来在like表中找到一个条目,如下所示:FINDinlikeWHEREuser_id==params[:user_id]ANDpost_id==params[:post_id](对于一种情况,我将使用:Like.find_by_user_id(params[:user_id]))我的问题是:如何使用ActiveRecordGem运行具有多个条件的查找查询? 最佳答案 使用where:Like.where('user_id=?ANDpo

ruby-on-rails - ActiveRecord .... activerecord-mysql-adapter

这让我发疯。我正在尝试创建一个简单的初学者应用程序,利用ActiveRecord来执行简单的数据库任务。我没有使用Rails。我不断收到错误:RuntimeError:Pleaseinstallthemysqladapter:`geminstallactiverecord-mysql-adapter`(Couldnotfindmysql(~>2.8.1)amongst[actionmailer-3.1.3,actionpack-3.1.3,activemodel-3.1.3,activerecord-3.1.3,activerecord-sqlserver-adapter-3.1.4,

mysql - Rails 数据库连接池的工作原理

我正在学习Rails数据库连接池概念。在Rails应用程序中,我将池大小定义为5。我对连接池大小的理解如下。当服务器启动时,rails会自动创建n个在database.yml文件中定义的连接。在我的例子中,它将创建5个连接,因为池大小为5。在每个http请求上,如果需要访问数据库,rails将使用连接池中的可用连接来处理请求。但我的问题是,如果我一次达到1000个请求,那么大部分请求将无法访问数据库连接,因为我的连接池大小只有5个。我上面对rails连接池的理解对吗??谢谢, 最佳答案 目的:数据库连接不是线程安全的;所以Activ

ruby-on-rails - 为 Ruby on Rails 3.1.0 安装 mysql2 gem

我收到这个错误Gemfileswillremaininstalledin/home/mark/.bundler/tmp/28288/gems/mysql2-0.2.17forinspection.Resultsloggedto/home/mark/.bundler/tmp/28288/gems/mysql2-0.2.17/ext/mysql2/gem_make.outAnerroroccuredwhileinstallingmysql2(0.2.17),andBundlercannotcontinue.Makesurethatgeminstallmysql2-v'0.2.17'succ

sql - Rails SQL COUNT N+1 效率低下

我有一个博客。在我的索引页面上,我拉入了所有博客文章。对于每篇博客文章,我都会计算该文章的评论数。这会导致N+1问题。我的查询如下所示:SELECT"blog_posts".*FROM"blog_posts"WHERE("blog_posts"."published"='t')ORDERBYpublished_atDESCSELECT"users".*FROM"users"WHERE("users"."id"IN(1,2,3))SELECTCOUNT(*)FROM"blog_comments"WHERE("blog_comments".blog_post_id=10)SELECTCOU

ruby - 如何在 ActiveRecord 中执行 LIKE % 查询?

我正在尝试查找一些包含特定字符串的项目。如果我这样做:MyModel.where("descriptionLIKE?",keyword)它将生成一个完全匹配的查询。我想让它生成一个LIKE%keyword%查询。我该怎么做? 最佳答案 like_keyword="%#{keyword}%"MyModel.where("descriptionLIKE?",like_keyword) 关于ruby-如何在ActiveRecord中执行LIKE%查询?,我们在StackOverflow上找到一

ruby - 在 Ruby 中拆分具有多个分隔符的字符串

举个例子,我有一个这样的字符串:options="Cakeorpie,icecream,orpudding"我希望能够通过或、、和或拆分字符串。问题是,我已经能够做到这一点,但只能先解析、和,或者,然后在处拆分每个数组项>或,然后像这样展平结果数组:options=options.split(/(?:\s?or\s)*([^,]+)(?:,\s*)*/).reject(&:empty?);options.each_index{|index|options[index]=options[index].sub("?","").split("or");}结果数组如下:["Cake","pie